package com.learn.algorithm;

/**
 * 给定一个数，算出平均值是整数的算法。
 * 例如：5 平均 2 份，则结果为，2 和 3；
 * 8 平均为 3 份，则为 2，3，3；
 * 11 平均 4 份，则为 2，3，3，3；
 * 15 平均 3 份，则为：5，5，5。
 * 求算法
 */
public class MatchDivide {
    public static void main(String[] args) {
        addDivide(8,3);
    }
    //对数组值求和
    public static int sum(int[] res) {
        int sum = 0;
        for (int i: res) {
            sum += i;
        }
        return sum;
    }

    public static void addDivide(int m ,int n) {
        if ( n <= 0 ){
             return;
        }
        int res[] = new int[n];
        int i = 0;
        while (true) {
            if (sum(res) == m) {
                System.out.println("sum:"+sum(res));
                break;
            } else {
                System.out.println("> "+i+"%"+n+" = "+i%n);
                res[i%n] += 1;
                i++;
            }
        }
        //结果存在数组里
        for ( int j : res) {
            System.out.println("->"+j);
        }
    }
}
